# 给定一个整数数组 nums 和一个整数目标值 target，请你在该数组中找出 和为目标值 的那 两个 整数，并返回它们的数组下标。 
# 
#  你可以假设每种输入只会对应一个答案。但是，数组中同一个元素在答案里不能重复出现。 
# 
#  你可以按任意顺序返回答案。 
# 
#  
# 
#  示例 1： 
# 
#  
# 输入：nums = [2,7,11,15], target = 9
# 输出：[0,1]
# 解释：因为 nums[0] + nums[1] == 9 ，返回 [0, 1] 。
#  
# 
#  示例 2： 
# 
#  
# 输入：nums = [3,2,4], target = 6
# 输出：[1,2]
#  
# 
#  示例 3： 
# 
#  
# 输入：nums = [3,3], target = 6
# 输出：[0,1]
#  
# 
#  
# 
#  提示： 
# 
#  
#  2 <= nums.length <= 103 
#  -109 <= nums[i] <= 109 
#  -109 <= target <= 109 
#  只会存在一个有效答案 
#  
#  Related Topics 数组 哈希表 
#  👍 10877 👎 0


from typing import List


# leetcode submit region begin(Prohibit modification and deletion)
class Solution:
    def twoSum(self, nums: List[int], target: int) -> List[int]:
        # {num: i}
        d = {}
        for i, num in enumerate(nums):
            if target - num in d:
                return [d[target - num], i]
            d[num] = i
        return []


# leetcode submit region end(Prohibit modification and deletion)

"""
将值和位置存在字典里
"""


# def twoSum(self, nums: List[int], target: int) -> List[int]:
#     # num : i
#     d = {}
#     for i, num in enumerate(nums):
#         if target - num in d:
#             return [d[target - num], i]
#         else:
#             d[num] = i
#     return []


def log(*args, **kwargs):
    print(*args, **kwargs)


if __name__ == '__main__':
    s = Solution()
    nums = [2, 7, 11, 15]
    result = s.twoSum(nums, 9)
    assert (result[0] == 0 and result[1] == 1), result
